这种模式就是传统的异步非阻塞Server
。在Reactor
内直接回调PHP
的函数。如果回调函数中有阻塞操作会导致Server
退化为同步模式。worker_num
参数对与BASE
模式仍然有效,swoole
会启动多个Reactor
进程。
BASE
模式下Reactor
和Worker
是同一个角色
BASE模式的优点:
BASE
模式没有IPC
开销,性能更好BASE
模式代码更简单,不容易出错
BASE模式的缺点:
TCP
连接是在Worker
进程中维持的,所以当某个Worker
进程挂掉时,此Worker
内的所有连接都将被关闭- 少量
TCP
长连接无法利用到所有Worker
进程 TCP
连接与Worker
是绑定的,长连接应用中某些连接的数据量大,这些连接所在的Worker
进程负载会非常高。但某些连接数据量小,所以在Worker
进程的负载会非常低,不同的Worker
进程无法实现均衡。
BASE模式的适用场景:
如果客户端连接之间不需要交互,可以使用BASE
模式。如Memcache
、Http
服务器等。
多进程模式是最复杂的方式,用了大量的进程间通信、进程管理机制。适合业务逻辑非常复杂的场景。Swoole
提供了完善的进程管理、内存保护机制。
在业务逻辑非常复杂的情况下,也可以长期稳定运行。
Swoole
在Reactor
线程中提供了Buffer
的功能,可以应对大量慢速连接和逐字节的恶意客户端。另外也提供了CPU
亲和设置选项,使程序运行的效率更好。
进程模式的优点:
- 连接与数据请求发送是分离的,不会因为某些连接数据量大某些连接数据量小导致
Worker
进程不均衡 Worker
进程发送致命错误时,连接并不会被切断- 可实现单连接并发,仅保持少量
TCP
连接,请求可以并发地在多个Worker
进程中处理
进程模式的缺点:
- 存在
2
次IPC
的开销,master
进程与worker
进程需要使用UnixSocket
进行通信 - 不支持某些高级功能,如
sendwait
、pause
、resume
等操作